package drg_group.beijing_2022.MDC;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

import drg_group.beijing_2022.Base;
import drg_group.beijing_2022.MedicalRecord;
import drg_group.beijing_2022.ADRG.*;

public class MDCL{
    public static String group(MedicalRecord record){
        String[] mdc_zd={"T83.002","C65.x01","E11.200x028+N08.3*","S37.200","E14.200x212+N08.3*","N11.802","S37.002","N07.700","N18.100","N28.819","T86.107","Q62.100x802","S37.000x032","C64.x00x003","Z49.101","C68.804","N03.000","R79.802","N25.004","N18.501","N06.900","M31.102+N08.5*","N36.802","Q64.402","N27.900","E10.200x029+N08.3*","N32.807","N31.200x001","T86.106","R82.600x001","S37.300x005","N36.803","R82.500x006","Q61.200","N34.200x003","E11.200x026+N08.3*","C79.001","D30.200","N10.x01","Q61.801","Q64.700x904","N05.101","N00.900x008","N28.001","N32.806","N00.900x006","Q64.707","N39.401","N00.900x002","N34.201","E10.200x023+N08.3*","N36.805","N32.400","N36.003","I12.900x008","M32.101+N08.5*","C67.200","D09.101","R94.402","N34.204","N02.900x002","N39.404","N02.600","N06.300","E66.902+N08.4*","N17.200x002","Q60.100","R93.405","Q63.102","R93.400x002","N99.808","N11.901","N06.800","D30.300","N32.802","C68.800","D21.506","T19.800x001","Q62.300x901","R82.000","Q63.900","N32.301","N03.800x004","N14.400","N32.800x012","N19.x02","N28.817","E13.200x521+N08.3*","R82.500x003","S37.310","N18.400","T83.100x002","N28.832","Q87.808","E11.400x380+G99.0*","R35.x00x003","Q63.800x101","N05.900x003","N28.822","N15.101","N04.501","D41.200x001","Q61.500","R80.x00","N32.804","R82.700","M31.305+N08.5*","E85.002","S37.001","T79.500","N21.000","N36.100","N28.826","N30.806","Q62.700x101","N28.004","N03.900","D30.302","N99.800x006","N31.200x006","N02.801","N28.828","E14.200x213+N08.3*","Q64.700x701","T86.100x003","S37.300x083","N28.900x017","E11.200x214+N08.3*","N13.400","T86.100x006","E14.200x012+N08.3*","A41.902+N08.0*","C64.x00x004","Q60.300","S37.300x082","N04.900","S37.000x031","N32.809","R82.500x007","N04.001","E14.200x029+N08.3*","N18.902","Z49.000x002","N13.302","Q61.402","N10.x00","T83.804","N03.801","T28.300","N28.836","T82.800x001","N28.811","N13.201","D41.001","Q63.101","Q63.801","R82.300","D18.000x819","N32.000","C67.500","N06.500","N34.300","N39.001","E10.200x092+N08.3*","Q64.100x091","Q87.800x903","I12.900x006","N06.100","T83.004","N34.101","S37.000","T83.100x003","R35.x00x001","E14.200x030+N08.3*","N28.002","D41.300x001","E11.200x212+N08.3*","R93.400x001","E14.200x015+N08.3*","N28.814","N02.701","N28.809","N99.803","Q63.301","E10.200x091+N08.3*","N04.800x002","N35.901","S37.300x081","N03.800x001","N06.400","N15.900x003","Q85.903","D09.100x001","T83.500x003","D41.700","N31.200x003","N05.000x001","S37.302","C79.100x002","D30.301","N13.000","N07.300","N28.818","M31.002+N08.5*","N07.900x001","M31.701+N08.5*","D18.000x811","N21.100","N28.839","N39.900","N13.600x002","N03.500x003","E14.200x215+N08.3*","S37.003","Q64.000","N20.901","N32.810","Q85.900x013","C95.900x007+N16.1*","Q64.303","Q63.103","Q61.901","N00.901","N31.202","Q62.300x905","S37.813","M32.102+N16.4*","N32.803","N30.000","N11.900x001","E10.200x026+N08.3*","S37.300","R39.101","Q64.708","N21.001","N28.837","I12.904","D41.900x001","N36.302","E11.200x025+N08.3*","R39.801","N11.000x001","Q63.201","S37.200x011","N30.810","N36.300","D30.900","N17.200x003","E13.201+N08.3*","N05.400","N03.400","C66.x00x003","N13.203","S37.010","N01.000","M35.007+N16.4*","N99.101","E72.007","N00.700","T86.104","N30.900","T83.101","N13.301","S37.101","R82.900x003","E10.200x030+N08.3*","N05.900x002","N11.900x003","N30.803","N28.833","Q61.400","Q62.300x902","E14.200x023+N08.3*","Q51.701","Q64.302","Q64.200x001","N32.800x014","N30.400","E11.400x381+N33.8*","N17.002","N30.802","M31.100","Q64.200x021","T82.800x004","C76.301","E11.200x015+N08.3*","Q64.304","C68.000","I12.000x001","N30.801","N32.815","R93.400x003","R39.000","Q60.200","E10.200x213+N08.3*","R34.x02","E85.411+N29.8*","N14.000","C90.005+N08.1*","S37.211","S37.303","E10.200x015+N08.3*","E10.200x024+N08.3*","N31.901","N36.808","Q64.900","N13.600x001","N32.104","Q62.800","N05.803","D30.701","N03.501","N32.800x019","Q64.700x901","N04.300x001","N32.900x002","N32.800x003","C68.900","R82.900x002","N39.403","N20.000x002","E14.200x011+N08.3*","N35.900","N99.001","C67.900x002","N32.200","Q64.705","N13.600","D41.000x001","N07.000","M10.005+N22.8*","N11.801","E11.201+N08.3*","N23.x00","N03.300x001","N18.300","Q63.203","N07.100","N20.000x003","Q61.300","Q60.400","T81.800x011","N11.100","S37.200x081","R80.x00x003","Q62.100x902","N27.100","Q64.301","C64.x00x001","N18.500","Q64.800x001","N28.834","N17.200","N35.000x001","N35.800","Q62.600","C95.900x017+N16.1*","N26.x01","N13.502","R82.200","T82.800x003","N32.202","Q64.403","S37.300x011","R93.403","Q62.700","E10.200x211+N08.3*","N28.900x004","N17.001","N34.001","T86.100x008","Q64.400x902","N28.813","N01.600x001","S37.201","N28.831","C79.101","E10.200x212+N08.3*","N02.203","N21.900","E10.200x031+N29.8*","S37.301","N39.405","E10.200x214+N08.3*","N01.400x001","N32.204","N34.000","Q61.403","Q64.706","N02.401","C67.100","D41.201","N13.503","N20.900x001","N30.901","N39.800","N18.904","N32.811","N04.700","N11.900","R82.901","I12.900x002","N36.004","N34.102","N03.900x003","N28.806","E10.200x025+N08.3*","T83.100","N25.805","Q61.404","T83.501","N28.805","Q62.300x301","Q62.400x002","N28.101","C76.303","N32.101","Q62.601","S37.200x022","Q62.400","R94.400","N17.900x002","Q62.104","Q63.001","Q60.000","R80.x01","I12.900x005","C68.805","N28.802","S37.300x021","N01.200x001","N32.808","N07.800","N36.901","D09.103","D17.700x016","E14.400x381+N33.8*","N34.000x005","N17.901","D30.000","N20.000x001","Q62.301","N28.807","N32.813","S37.200x024","N17.800","B65.002+N22.0*","N02.502","N04.101","E11.200x013+N08.3*","N39.300","N02.002","N39.300x002","C67.900","N02.101","N07.600","E11.200x213+N08.3*","Z49.201","N13.601","S37.000x022","N32.805","N17.900","N31.200x007","N18.200","T83.100x004","N02.800x003","N07.500","R33.x00","E14.200x017+N08.3*","R31.x00","N36.201","N28.803","E12.400x002+N33.8*","N27.000","N28.827","E11.200x014+N08.3*","E14.200x031+N29.8*","C68.802","T19.100","Q61.000","N04.903","Q64.401","R82.800","N15.000","N28.800x001","Z46.800x001","N99.100","N35.000","Q85.900x029","I12.900x001","C67.800","N03.502","N28.821","R94.802","R80.x02","Q62.100","T83.800","N00.801","N03.601","N20.002","M31.003+N08.5*","N32.812","N34.100","Q64.501","N28.808","E10.201+N08.3*","N28.900x010","N03.700","N05.701","Q62.201","N30.807","T83.103","T83.802","Q64.703","E14.200x025+N08.3*","S37.200x023","T86.100x005","E10.200x016+N08.3*","N00.000","N06.600","N28.102","N28.824","E14.200x026+N08.3*","N13.602","N99.000","Q62.602","Q64.502","C67.700","D41.901","E11.200x012+N08.3*","N28.815","N25.001","E10.200x017+N08.3*","Q61.900","Q64.700x601","N13.605","N28.812","N06.001","C67.501","N12.x02","E11.200x030+N08.3*","N28.900x026","N39.400","N99.100x005","N28.005","N00.600","N17.900x004","D89.101+N08.2*","N04.300x003","N04.902","T83.500x002","N00.500","N25.100","T83.000x001","N36.001","N03.200x001","Q64.700x201","Z45.800x007","E10.200x011+N08.3*","D09.104","N04.502","N06.200","N28.100","N17.101","N18.900x011","N30.805","N32.800x008","E14.200x016+N08.3*","N26.x02","N26.x00","N30.300","R39.100x001","N34.202","R32.x00","N13.204","N32.901","Q60.501","N32.814","Q63.002","N99.805","N05.900","R82.902","N30.201","N13.701","N39.800x001","M35.006+N16.4*","N13.300x005","Q62.300x903","T19.000","N15.900x004","N05.000x003","N13.600x004","N20.000","N02.900x001","E11.200x016+N08.3*","N18.901","N28.838","N10.x02","D30.400","E10.200x013+N08.3*","N00.902","C65.x00","N04.102","N00.301","N02.702","T83.800x001","N32.203","C68.801","N11.800x003","R34.x01","E11.200x017+N08.3*","N30.808","N17.900x003","S37.004","C67.400","N13.504","Q63.200","C67.300","N32.300","N00.200","N14.102","N20.001","Q62.700x001","S37.000x023","M10.001+N16.8*","D41.400x004","T81.800x014","N25.802","N11.800x002","E14.200x021+N08.3*","D30.100","N13.100x001","N28.900x013","N02.900","Q64.600","E11.200x092+N08.3*","N04.801","N13.500x010","D09.000","N20.200x001","N28.829","N30.100","T19.801","Q63.800x902","Z46.800x002","N03.900x006","N01.900x003","N32.001","C79.103","N02.802","N32.801","T86.105","Q62.300x101","N03.900x004","N14.301","N32.800x009","Q64.704","N13.604","Q62.400x001","Z49.000","Q62.700x201","N05.501","N25.803","N05.900x009","D41.401","I86.201","N01.900","E14.200x211+N08.3*","N34.203","N35.100x001","Q64.700x902","N30.809","N15.901","E14.400x380+G99.0*","N04.601","N99.100x003","Q62.101","N01.900x001","N99.806","Q62.103","E14.200x214+N08.3*","N28.003","N14.101","N28.801","T82.800x005","N05.201","C79.102","E11.200x027+N08.3*","N25.806","N19.x01","Q60.500","Q64.200","S37.300x004","N03.900x005","N32.102","N01.100x002","E11.200x091+N08.3*","R30.000","N28.830","E83.100x008+N16.3*","N12.x03","E10.200x027+N08.3*","T83.200","N01.700x001","N32.100","R30.900x001","T86.102","E11.200x031+N29.8*","E85.403","N25.800x006","N28.804","N31.800","Q64.701","N36.301","Q64.100","N13.603","Q64.700x801","N34.002","R39.200","C65.x02","N03.503","D69.005+N08.2*","N01.500x001","T83.003","D09.102","N30.804","C90.004+N16.1*","I13.100x001","N17.000","N36.804","N39.402","N99.800x011","R93.404","N05.900x007","N20.900","E14.200x024+N08.3*","N05.802","T83.100x001","T83.500","N28.902","R93.401","S37.000x013","N31.203","N02.302","Q27.305","N06.700","N05.000x004","N13.901","N28.835","R30.100x001","N31.100x001","E11.200x011+N08.3*","N13.801","Q42.200x201","S37.011","T83.102","N02.001","Q62.202","N39.000","N25.804","N13.202","R39.200x001","S37.000x015","M31.703+N08.5*","C79.000x001","Q64.702","N02.301","N15.900x002","S37.300x031","I12.900x003","C68.800x003","Q61.100","N21.800","E11.200x023+N08.3*","N02.102","E10.200x215+N08.3*","I12.900x009","Q62.500","S37.000x012","R36.x01","T86.811","C68.100","S37.100","T86.100x007","N15.102","R82.500x005","T28.800","T83.001","N01.800","Q62.200","N00.900","N99.500","R30.100","Q62.000","E14.200x014+N08.3*","A02.205+N16.0*","R82.500x004","N03.800x003","S37.000x016","E11.200x029+N08.3*","R32.x01","N17.100","N25.900","Q63.000","N03.901","Q63.302","E11.200x024+N08.3*","N19.x03","N31.000x001","N00.400","N05.600","N32.201","N39.200","N36.000x007","C67.000","N30.902","D41.400x001","C67.600","N32.103","N34.200x006","E14.200x092+N08.3*","Q60.600","Q61.800","E72.006+N29.8*","E10.200x028+N08.3*","N03.100","N19.x00","C66.x00x002","N36.000","N39.100","Q61.401","E14.200x028+N08.3*","N36.807","N36.002","D41.301","E14.200x013+N08.3*","R39.100x002","N00.800x001","R93.402","T19.900","T83.801","N04.200x001","S37.111","T86.100x002","N01.900x002","Q60.400x001","N28.816","N28.823","E10.200x012+N08.3*","C48.001","R30.000x002","N07.200","R94.401","N04.901","N12.x01","N14.201","N32.002","N05.301","N12.x00","T86.103","N36.806","N02.201","N31.201","Q62.300x904","D18.000x806","E11.200x211+N08.3*","N00.802","N15.801","T86.100x001","N03.900x007","N01.300x001","N34.205","Q64.400x301","N13.506","E11.200x215+N08.3*","N36.005","N36.809","R35.x00","N34.200x004","N31.200x002","N07.400","R94.803","N20.100","E12.200","Z52.400","N00.900x009","D41.100x001","N05.900x006","N00.100x001","N03.900x002","Z49.000x004","N36.200","E14.200x027+N08.3*","D41.101","E14.200x091+N08.3*","N30.800x004","E10.200x014+N08.3*","N28.810","N13.501","N28.825","A40.901+N08.0*","S37.814","C66.x00","N28.820","T79.500x002","C68.803","N28.901","N04.400x001","N05.801"};
        String[] dept_list={};
        if (!(true && Base.contains(mdc_zd,record.zdList[0]))){
            return "";
        }
        
        Base.groupMessages.putMessage(record.Index,"符合MDCL入组条件，匹配规则：主诊断匹配");
        String result;

        result=LA1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LA2.group(record);
        if (result.length()>0){
            return result;
        }

        result=LB1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LB2.group(record);
        if (result.length()>0){
            return result;
        }

        result=LC1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LD1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LE1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LF1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LJ1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LL1.group(record);
        if (result.length()>0){
            return result;
        }

        if (false && record.ssList!=null && record.ssList.length>0  && Base.intersect(Base.SS_VALID,record.ssList)){
            Base.groupMessages.putMessage(record.Index,"符合LQY入组条件，存在有效手术操作："+String.join(",",Base.Intersect(record.ssList,Base.SS_VALID)));
            return "LQY";
        }

        result=LR1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LS1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LT1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LU1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LV1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LW1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LX1.group(record);
        if (result.length()>0){
            return result;
        }

        result=LZ1.group(record);
        if (result.length()>0){
            return result;
        }

        Base.groupMessages.putMessage(record.Index,"不符合MDCL的ADRG入组条件");
        return "";
    }
}

